Websydian v6.1 online documentationOnline documentation - Websydian v6.5

Introduction to PaymentWebShop


Introduction

The PaymentWebShop pattern is an extension of the WebShop pattern where facilities for communication with a Payment Gateway has been added. This enables the Ordering.Submit Payment function to actually submit a payment request with credit card data to a payment gateway and the WebShop application to receive the response.

A Payment Gateway is a third-party server that provides services to clear credit card information, i.e. to authenticate the credit card information and to reserve the amount requested, services to capture the amount, i.e. to request that the amount is transferred to the bank account of the shop, and other services.

A web-based shop application does not directly send events as HTTP requests to a payment gateway. Instead the web documents of the shop include an external URL referring to the payment gateway, e.g. through the ACTION parameter of an HTML FORM for a "Submit Payment Ok" button. 

When the web user selects "Submit Payment", the event together with credit card data and amount is send to the payment gateway referred to by the external URL. The payment gateway then verifies the credit card, and, depending on the success of this, requests that the shop application either generates an Ok page or an Error page. This result page is relayed back to the web user as a HTTP response. 

This is illustrated in the event trace diagram below:

Successful Submit Payment Event Trace Diagram

Successful Submit Payment Event Trace Diagram

If the credit card verification fails, a LoadErrorPage event will be sent instead, and the WebShop application should then instead generate a Payment Error document.

The shop application does not receive the credit card data at all; these fields are only available to the payment gateway. A payment gateway typically operates under SSL security.

This sligthly complicated event and page exchange scheme make it possible to make online payment without the need for the web user to change to another site, or experience that the control is changed to another site. It is complete transparent to the web user that the point of control is changed forth and back between the webshop application and the payment gateway.

ExternalServerControl terms

The PaymentWebShop uses the Websydian ExternalServerControl pattern for control of event exchanges with a payment gateway. A few terms need to be defined, corresponding to abstract functions of this pattern.

In the above illustration Submit Payment. Ok is a SendToExternalServer event, LoadOkPage is a ReceiveFromExternalServer event and Submit Payment is a PageGeneratorWithExternalEvent function.

Payment Gateway Protocol

The events exchanges with the payment gateway and the parameters associated with the events together constitutes a payment gateway protocol. The various third-party payment gateways all have different protocols for their events and required and optional parameters.

Some payment gateway protocols require that the web document for payment submission containing the blank credit card fields must be relayed through the payment gateway. If the payment gateway operates as a secure site under SSL control this approach will ensure that the web user sees a padlock-symbol in the browser when the Submit Payment document is displayed (assuming frames are not used): Marker for SSL-secure site

Other payment gateway protocols only require that the clearing event (the Submit Payment.Ok event) is handled by the payment gateway.

Payment Gateway Assumptions

Since various payment gateways protocols are different, the Websydian PaymentWebShop has been developed with some minimum assumptions of the protocols and with support for the widest array of payment gateway protocols. 

The Websydian PaymentWebShop pattern is made using the following assumptions:

The exact name, length and other attributes of the fields are determined by the field implementation, and is configured during the implementation of the PaymentWebShop application.

These are the basic assumptions, and a PaymentWebShop application can easily be modified to include other payment gateway events and other payment gateway fields. This is described in detail in the PaymentWebShop Other Uses section

Dynamic Payment Gateway Event URL's

Normally all URL's within a Websydian application refers to the Websydian Event Dispatcher:

<FORM ACTION="/WSYSHOP/WDISPAT.EXE" NAME="AAmhF" METHOD="POST">
...
</FORM>

Events that should refer to a external payment gateway URL need to have this URL dynamically substituted instead of using a static URL. This is obtained by using a replacement marker for the FORM ACTION attribute: 

<FORM ACTION="/(CLEARURL)" NAME="AAmhF" METHOD="POST">
...
</FORM>

This replacement marker for External URL will appear in the generated Document Template for the Ordering.Submit Payment Document, and at run-time it will be substituted by the value of the field PaymentClearingURL of the Shop entity. 

Payment Gateway Needs Result Return Addresses

The Submit Payment.OK event initiates the credit card clearing process at the payment gateway. When the payment gateway has performed the clearing process and the credit card has been successfully or non-successfully validated, it request a result page from the WebShop application by sending the LoadOkPage or the LoadErrorPage event.

It is obvious from this that the payment gateway somehow should know the result return addresses. Various approaches to this exists, depending on the payment gateway.

Some payment gateway store the LoadOkPage and LoadErrorPage return addresses in a database when the payment shop is configured, and use the ApplicationID for look-up.

Others require the LoadOkPage and LoadErrorPage return addresses send as parameters to the Submit Payment.OK event. Refer to the specific protocol documentation for your payment gateway to find out what applies.

Digital Signature and Payment Gateways

In a Websydian application secured with hidden field integrity checking by digital signatures, signing of hidden fields are based on that the digital signature is transferred from web user to the web application in a special hidden field WSYBASE/Signature with implementation name "WSYD_SIGN".

For a specific payment gateway protocol, the gateway events may not include a parameter that can hold the digital signature. Therefore the generated digital signatures for External Events are stored in the Session table in the field LastExternalSignature when a SendToExternalServer event is sent, and the signature of the fields of the first incoming ReceiveFromExternalServer event is compared to this stored value.

In order to prompt that the digital signature is calculated and stored in the Session table by a PageGeneratorWithExternalEvent function, the "/(WSYD_SIGN)/(implname)" replacement marker for the SendToExternalServer event must be included in the HTML Document Template. Where it is placed is not important. 

The /(implname)  must hold the implementation name of the external event that is sent to the payment gateway. It is recommended that you place within an HTML comment. 

Example for the Submit Payment.Ok event FORM:

<FORM ACTION="/(CLEARURL)" NAME="AAmhF" METHOD="POST">
<INPUT TYPE="HIDDEN" NAME="sessionid" VALUE="/(sessionid)">
<INPUT TYPE="HIDDEN" NAME="myshopid" VALUE="/(myshopid)">
<INPUT TYPE="HIDDEN" NAME="amount" VALUE="/(amount)">
<P>Credit Card Number<INPUT TYPE="TEXT" NAME="cardnum" VALUE="/(cardnum)"</P>
<P>Expires year<INPUT TYPE="TEXT" NAME="eyear" VALUE="/(eyear)"</P>
<P>Expires month<INPUT TYPE="TEXT" NAME="emonth" VALUE="/(emonth)"</P>
<INPUT TYPE="SUBMIT" NAME="OK" VALUE="OK" >
</FORM>
<!--/(WSYD_SIGN)/(AAmhF) -->

In the Submit Payment.Ok event FORM the three hidden fields will be signed, and the digital signature will be stored in the Session table.

When a response comes from the Payment Gateway through either LoadOkPage or LoadErrorPage events, the same fields will be signed again, and the signature compared with the signature stored in Session.LastExternalSignature.